-
Notifications
You must be signed in to change notification settings - Fork 3.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Avoid writing NaN and Infinity with json format table #24558
base: master
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could you add a test?
@@ -123,7 +123,16 @@ else if (REAL.equals(type)) { | |||
return (generator, block, position) -> generator.writeNumber(REAL.getFloat(block, position)); | |||
} | |||
else if (DOUBLE.equals(type)) { | |||
return (generator, block, position) -> generator.writeNumber(DOUBLE.getDouble(block, position)); | |||
return (generator, block, position) -> { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What about REAL type?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
'NaN' and 'Infinity' getting casted as Double it seems. It goes through double datatype.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think so. Please try CREATE TABLE test_nan WITH (format = 'json') AS SELECT real 'NaN' a;
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
okay
360d7a0
to
a0b1253
Compare
a0b1253
to
bc3afbe
Compare
if (!Float.isNaN(value) && !Float.isInfinite(value)) { | ||
generator.writeNumber(value); | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Float.isFinite()
will cover both infinite and NaN, as the comparison of NaN with any Float (MAX_VALUE in this case) will return false
Same apply to Double
type handling below
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
okay,
@@ -120,10 +122,26 @@ else if (type instanceof DecimalType decimalType) { | |||
}; | |||
} | |||
else if (REAL.equals(type)) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Similar logic is also in createMapKeyFunction(Type type)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
even though they will not break as these, but still worth discussing on how those values supposed to be read back especially considering cases like duplicate map keys of NaN etc., or just leave them as is and that the downstream consumer decide
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In other cases, we've preferred to emulate the Hive SerDe behavior. What happens in Hive if you serialize maps with NaN
/ Infinite
/ -Infinite
keys there, @sug-ghosh ?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@pettyjamesm will check this
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@pettyjamesm In hive, it basically store it as NULL, 'NaN / Infinite / -Infinite' for all values.
lib/trino-hive-formats/src/main/java/io/trino/hive/formats/line/json/JsonSerializer.java
Outdated
Show resolved
Hide resolved
bc3afbe
to
846c640
Compare
fixes #20395 #20395
This pr will fix inserting NaN and Infinity into table as Json Format.
In hive, if we insert NaN or Infinity in json format table, it would store that as NULL, which readable from Trino. We can go that path also if we want to create table to be successful.
@ebyhr @hashhar
Description
Additional context and related issues
Release notes
( ) This is not user-visible or is docs only, and no release notes are required.
( ) Release notes are required. Please propose a release note for me.
( ) Release notes are required, with the following suggested text: